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Fares I would like ta thank Dave Boyce, Dave Mitchell and 
Poh Kitch who submitted their articles on tape and disk. it 
greatly reduces the risk of errors creeping in. Thanks fellas. 
Some promised articles had to be held over till next issue. 


SNOOPY CALENDAR PART 1 by Dave Boyce :- Page 4-6 
Due to the leneth of this program part two will be in the 
next issue. Snoopy calendar consists of two parts. Part one is 


the calendar while part two is snoopy himself. 


UTTLITY REVIEW = Wer. TAPEZ DISK <== Page 7 

Tape W.Presssor to Disk conversion utilities which will 
allow you toa convert your Tape W.P. for full disk use and will 
also transfer your tape W.P. files to disk. 


MERGING W. PROCESSOR FILES (TAPE OR DISK) :- Page 7% 
A brief description on the procedure. The insruction boak 
only mentions that it’s possible using the LOAD command. 


INTRODUCTION TO PROGRAMMING BY B. KITCH :- Pages 8-10 

This is the second informative part and contains a lot af 
gnad advice an how to become a competent programmer. 
Unfotunately a lot of people skip over many articles in 


preference +o more attractive material in magazines. As Bab 
mentions it’s very important to plan your program if you want to 
improve your skills. 


OTHER VZ PUBLICATIONS :- Page 10 

Ther are two other VZ publications besides ours. VZ USER is 
on the advanced side while LE’VZ 200/300 OOP is more general in 
application. Both are informative and exellent value for money. 


TECHNICAL REPORT 1 by Joe Leon :- Pages 11-12 

The proiect shows how to fit a write protect override switch, 
change the adnill motor on led to a super bright one and a power 
aonvoff switch ta your disk drive. 


RESTORE BY Ds MITCHELL e-= Pages 13-15 

This is a handy utility that will RESTORE your progam after 
usine the NEW command. May also work after using reset button. 
HIGH GAMES SCORE <= Page 15 


Net much activity in this area but should see some new champs 
after the school holidays. 


TECURICAL REPORT 2 by «Joe Leon. += Pages 16-17 

Two circuits are shown for an electronic shift lock key. 
UNDERSTANDING YOUR VZ by Robert Quinn :- Pages 18-20 

This is the final in the series and hopefully not the last we 
hear from Robert. Quite afew people should understand their 


VZ°S a lot better now. Much appreciated Robert. 


BOTH BALK. a 
IT appears our members have more bark than byte as nobady hit 
hack as vet. This section is for your comments or queries: 


REGLEVE ile OR NOP. 3 

A 15 year old got a COMMODORE for Christmas, connected it 
all up. turned on the power and a READY message appeared on the 
screen. So he typed in YES and the latest news is he’s still 
Waiting. Things like that dont happen with the VZ, or do they ? 
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SEM6OoOorF YY CALenNbpARm CONT . 


am? SNOOPY CALENDAR FOR THE 

LOO BROTHER M-10008 OR EQUIV. 

110 °* DOT MATRIX PRINTER. 

20: FILE = SNOOPYCL 

ISO-CLASFRINT?: PRINT"“DO YOU HAVE YOUR PRINTER’ 

35 INPUT TURNED ON <YeN>" <DES 

TAO. [TE DES="Y"" THEN 155 

145 PRINT: PRINT" OH WELL !! - SWITCH OFF AND COME BACK WHEN", 
{SO PRINT" YOU HAVE. = BYE’! 2: END 

155 CLEARBOO 

(Ae. VS Se ! pe ea Sa SS a SS SS Se Se ee SS Se SSS 

165: DIM: LOT). YRC11.6,4),X%309 9) 

170 DATA 31,28,31.30, 31,30, 31,31, 30, 31, 30,231 

Tee) oer an ere Kees Ses hahaa hese = Lhe SSS X 
[7S DATA" O00000 274 "O0000000" <7 O00 OO" 5. OO 00", "OO WO” 
180 DATA"OO 00 6 “OO OO SOG 00" ,."GOQ000000".,." «QO0000 * 
185 DATA" 1 nou 11 Moon 111 nom 11 uo 11 n 
130 DATA" i Bg. il has Ld a Se ea A 
ISS DATA 2e22 27. Vy 2222 eee a Ae ee ee 2ata Beer ee 
20: “DATA 222222 4." 222 igs Wal Wee MDA 22 ee 2272727 
ZO DATA SOG a3 ISS ~ BOO O eos wt oo ee 33 nae Soo: - 
219 DATA" ico a 333", "33 Go 2 SSS ooagoo 4” S3S383an. ” 
2195 DATA" 4 ae 44 "," A44 "," 4444 ","“ 44 44 " 
229 DATA"44 44 ","44444444","44444444"," BA a 44 $" 
Zoo: DATAY SSs9500900 4." mon DOs. = OS ve Oo “OOOO 0ge 3 
230 DATA S22 sooo 4. oo ge oe 554" "Soom OD00 | 4 OD OIOo 
230 DATA” GeGeese *. "S66566666".:. "65 66... “Oe ", "666666E " 
2490 DATA"66566666", "66 bor >) Se 56". “6G6666666",;" OoO665666. ° 
2aS DATA CELE TIE ce PCE EEE a Lee a ee 
200 DATA" ee ce see ek eee ee gee 77 " 
Zoo TATA BORneas: "| HSseaesoco.' < ae Se Oe Sa." ." S8esee. ” 
2600 DATA” SES8R8R 7 "S33 RAR es 88", "88888888". " B8B888E " 
Zoo DATA Goagego. * "OSI 7g3o" 4 Se Soe eo gos OSGeo 
210° DATA Sagoo <7 oo ao Jo. “eso gds”.." BIg900:"" 
Fe ae pee Rakes aeee on ee hKeeeee = X 
273 POR 220 TO: Tis READ LCLICNEAT 1 

280 FOR [=0OTO 9:FOR J=OTO 9:READ X$(01I,J):NEXT J:NEXT I 

ioe. 

290 GOTO 440 

Zoo POR MSOro Wa 

Zoo: TREN 

BOW wWeO2 DIS] 

Om YR. DW) SDP Dre pret pa p+) 

310 IF D>6 THEN D=90:W=W+1:IF W>4 THEN W=0 

Ste: Diath sl THEN 7305 

320° NEXT M?*SOUNDL. 3 

320 RETURN 

330 QS=RIGHTS(STRSCY),4):1T1I=VALCMIDS(Q$,1,1)) 

S2a0 T22VaAILCR LDS (0S.2. 1732 1S=VALINIDS(QOS, 1)) 

3490 T4=VAL(MIDS(0O8,4,1)) 

345 LPRINT: LPRINT 

348 LPRINT TAB(25)3" Y3SVLesVoeeLGPRIENE 

Boo POR. T2370: 9 

Ne A ree ea aes ane is Oe ees epee ea erie Ae Cee Se {eS ==5 X--------- X 

ook, pee VER eT ae "+X$CI2,1) 

360) BS=BS+" ye LS ee "+X$(0T4,10) 

365 LPRINT TAB(25) : BS 

370 NEXT I 

375° GRRINT?LERUNT TABCZ5)°.°" "SV¥ZS3VZS:LPRINT CHRS( 18) 

SRO RETURN 


285 
390 
3905 
AOD 
405 
419 
415 
4A20 
425 
430 
435 
440 
445 
450 
4A55 
460 
462 
A6B5 
470 
ATS 
489 
A85 
490 
4935 
500 
BOOZ 
504 
SOD 
A190 
lo 
S29 
aI20 
5'30 
Doo 
538 
S40 
545 
BOO 
Dae 
Bae 
558 
SAO 
SAS 
SD 
aio 
ARO 
SB5 
588 
590 
BOO 
B10 
RO 
RAO 
B40 


SNOOP Y CALENDAR CONT .- ws - - = 


LPREINT A# 

FOR W=OTO 4:BS="" 

FOR - 1=0TO: 27 BS=hS+" : 

FOR J=010 6 

IF YROM4+1,J3,W)=O THEN CS$=" " ELSE CSH=STRS(YR(MN+I,0,W)) 
ITF LEN(C#)<3 THEN C$=" "4+C$ 

BS->BS+C$ 

NEXT J:NEXT I 

LPRINT BS 

NEXT W 

LPRINT: RETURN 

CLS:PRINTTAB(6)" VZ 200 CALENDAR": PRINT 

PRINT" THIS PROGRAM WILL GENERATE A CALENDAR FOR ANY "3; 


PRINT"YEAR IN THE RANGE 1901 - 1999. ALL YOU HAVE TO "; 
PRINT"DO IS SPECIFY THE YEAR!" 

Ate" SU MO TU WE TH FR SA":A$=AS+AS+AS 

‘~~-X-----~----~ X-X~--+---X-X------------------ X---------~ XK 
Hiss" "+" JANUARY "+" "+" FEBRUARY " 
H1S=H1s+" "4+ "MARCH" 

H27ss " "Ee" APRIE"+" tt 

H2S=H2S+ "MAY "+" "+" JUNE" 

H3$=" "4" JULY "+" "+" AUGUST " 
H3$=Has+" "4+" SEPTEMBER" 

H4S=" "+ "OCTOBER" +" "+ "NOVEMBER" 
H4$=H4$+" "+" DECEMBER " 

) ---X------~---- X-X------- X-X-------~---------- X---------- X 
SOUND1, 1 

INPUT" FOR WHICH YEAR WOULD YOU LIKE A CALENDAR "3Y 
PRINT" PLEASE WAIT -- I’M INITIALISING MY DATA..... 


IF ¥<190! OR Y>1999 THEN PRINT:PRINT"OUT OF RANGE":GOTO 505 
IF AX INTCY/“4)=Y THEN L(1)=29 

[=¥e19012J=INT CIs) la 1— 44 Je2 
K=5x(JI-7KINTCI/7) 241: D=K-7*# INTCKS 7) 


GOSUB 295 

SOUND 3,3:PRINT: INPUT"PRESS <RETURN> WHEN READY... "31 
PRINT" PLEASE WAIT ...I1I WILL NOW" 

PRINT" PRINT-OUT YOUR CALENDAR FOR" 

PRINT™ “THe: TEAR song 


GOSUB 820’°TO SNOOPY ROUTINE 

GOSUB S30 

LERINT CHRESt 2734". 2" 

M=O:LPRINT H1$S$:GOSUB 3&5 

M=2:LPRINT H28:GOSUB 385 

Mao: LYRINT H3e2GOSuUB. sa5 

M=S:LPFEINT H4¢-GOSUS. SS 

Clove RENT 

INPUT"ANOTHER YEAR "sYYS: IF YYS="Y" THEN RUN ELSE SISO 
END 

LPRINT CHRS(27); "@* 

CLEAR SO0:CLS:PRINT"BYE-BYE": FOR LL=1TO 10:LPRINT:NEXT LL 
END 


(a) 


— 
— 
-_= 


yD 


. 


O 


LPRINT CHR® C2733 "a" 3CHRSCisals * LINES 187216 <APART 
GLPRINT GHRSC 1S). “CONDENSED 
LPRINT: RETURN 


1500 ERA"SNOOPYCL" 
[600° SAVE"SNOOPYCL®’ <CLS= DIK 
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Altheneh the V2 has been around for several years, the 
hetter type utilities have been few and far between. The VZ tape 
Word Processor falls in this category, but unfortunately cannot 
be used with Disk. That used to he the case till Dave Mitchel’ 
af PRockhamptoan, Queensland did something about it. The result 
is that with D. Mitchell’s two utilities you can convert your 
Tape W. Processor for full Disk use or Tape LOAD, Disk SAVE. 


Mtrilityvy one t= This will convert your Tape W. Processoar 
for. {wi)l DISK wse. It will SAVE, LOAD and give DIRectories of 
your Disks. Needless to say, it loads/saves much faster than 


tape and you can see what files you have on Disk. The amount of 
free Disk space is also shown. One other built in feature is the 
ability to protect sensitive files from unautorised perusal by 
making them invisible to the DIRectory command. 


ia laity tao: as This simply converts your Tape W. Processor 
for Tape LOAD, Disk SAVE. IT allows you to transfer your Tape 
W. Processor files to Disk to be used with previous converted 
full Disk version of W. Processor. 


Both versions require a VZ 200/300 with 16K Ram Expansion. 


Fartunately for H.V. VZ Users’ Group D. Mitchell has donated 
the abnve canversian utilities as a fund raiser for H.V. VZ@ 
Users’ Group. The club owes him its’ gratitude. Thanks Pave. 


The two utilities are available from H.V. VZ Users’ Group for 
SAO OO and includes Disk, Conversion Programs, full 
instructions and Post and Packing anywhere in Australia. 


One thine we would like ta make absolutely clear is that we 
will not supply under any circumstances D. Smiths Tape W. 


Processor, You have to purchase it from D. Smith in the usual 
WAY. All we are selling is a means to convert your Tape W. 


Procestar for Pisk use. 


MERGING FILES (TAPE OR DISK) :- 


Although mentioned a couple times in the W. Processor 
instruction hook about MERGING files it does not tell you how to 
accomplish it. The procedure is quite straightforward. 


Syne: sl. Before MERGING files make sure vou have both files 
saved toa tape or disk. It is very easy to lose or corrupt ane oaf 
the files. 

Step 2. a Load first file from tape or disk. Enter EDIT mode 
and move the cursar toa bhottam af text. Press RETURN about 4 
times. Return to main menn. 


ntep 2 t= Load second file from tape or disk and the tuo files 
mill be MERGED. The second file will he appended to the bottam 
af file one. 


Any number of files can be MERGED up to W.P. memory capacity. 
Failure toa mave cursor ta bottom of text will wipe out previous 
text from cursor positian down. Use edit commands to rearanse or 
edit vour MERGED files. Like allways. test aut the procedure 
till you are satisfied vou understand its operation. 


Tr TRODUCCT Tr oTr TO PROGRAMMING = “ F2 
Part. 2= by -BoOb: Kitch. 


As mentioned in Part 1 of this series, the programming task 
is a large and complex feat of organization and requires a wide 
range of skills. It is possible, and best, to break the task 
down into six segments - each of which must be thought about, 
planned and then carried out to ensure the successful completion 
of asoftware project. Even a small program requires that a 
cursary consideration of the six segments be made —- although some 
of them may be quickly passed over as trivial. But it is certain 
that larger programs (more than 200 lines) require careful 
planning for success. 

Before describing the six steps, it is worth thinking about 
"What makes a GOOD program?" 

A program may be judged from a number of different 
Standpoints; each is not necessarily mutually exclusive and 
sametimes some conflicts require that a trade-off be made. 


The first criteria is that a program should be EFFICIENT. 
Efficiency can be considered from a number of varying view 


points. For example, Optimization of the run-time can be 
considered as efficient. Also, reduction in storage requirements 
for both program code and variables can be considered as 
efficient programming. Furthermore, and particularly if one is 
developing software commercially, then efficiency can be 


measured in terms of the actual time required to get an 
applications program running and the ease of maintenance of that 


code. The use of appropriate data types and data structures can 
greatly improve the efficiency of a program. The selection of a 
suitable algorithm can also assist. Finally, ease of debugging 


so that the pragram can be updated or modified may be considered 
desirable. 


The second criteria is GENERALITY and it is here perhaps that 


so many programs "score" so poorly. Rather than a program being 
written to solve 2 particular chore, it should be broadly 
Written ta handle a wide range of problems. The use of 
subroutines and functions developed and debugged previously can 
enormously improve programming productivity. Often a simple 


substitution of a variable for a constant in a program can 
broaden the the applicability of the program significantly. 


The final criteria is ELEGANCE, Which is a little harder to 
both define and achieve. An elegant program is one that is 
simple and ingenious, and fFassibly uses an algorithm or data 
Structure that may not be immediately obvious to the application. 

The so-called "programmer's tricks" are often elegant solutions 
to a programming problem; but beware, some are attempts by 
programmers to conceal their programming stategy. 


These then, are general guidelines to try and attain in your 
programming and by which to judge a particular programming effort 
as enad, mediocre or poor. Notice that they are not language 


specific comments and are equally applicable to any programming 
Janguage or exercise. 

To return to the six steps in the programming task - I will 
briefly discuss each in turn and ask that you consider each one 
when embarking upon your next programming exercise. Also as one 
Proceeds through the steps, it is often necessary toa recycle 
back through some of the preceeding steps, to iteratively 
improve the exercise and your understanding of ideas. 


’ 


| 


INTRODUCTION TO PROGRAMMING “ % 


1. PROJECT SELECTION. This may appear trivial, but we all 
have too many ideas for programs and rarely knaw which one to 


tackle next. Also be honest with yourself: some of the projects 
are probably too ambitious for your existing skills and an 
attempt upon these will possibly result in frustration and 


perhaps failure. Choose an exercise that is challenging and 
worthwhile. Try not to "reinvent the wheel", try to be aware 
through reading magazines or discussing with other Users what 
programs are already available. Modifying an existing program to 
suit your specifications is sometimes quicker - it also allows 
you to study how other programmers tackle problems. O.F., so 


now you have an idea or problem that you wish to tackle and 
solve. 

2. PROJECT FEASIBILITY. Again be honest. Do you have the 
hardware, software and know-how to achieve the result? Its is 
not really much use trying to write large business-oriented data 
base programs for an 8K tape-based VZ! Check that the task is 
reasonable. 

Bs PROJECT DEFINITION. This is where the idea starts to get 


translated into a reality. It is also the phase where generality 
can be written in. It is easiest to start by thinking about the 
input to the program. Is it keyboard oriented, or is it toa come 


from a programmble 1/0 port? Perhaps the program reads only DATA 
statments to configure itself or maybe the program must check if 
a printer is connected to the sytem? Start defining what the 
input will look like. Assign variable names with meaningful 
mnemonic names at this stage also. 

Next, define the output expected from the program. 13 2t to 
write to tape and in what format? Perhaps it is to be screen 
oriented - can sound be used - or perhaps voice synthesis to tell 
the operator what is going on? Plan very carefully and fully the 
layout of the expected output as this is how Users will initially 
perceive the quality of the progran. 

After defining the I/0 for the program we should now have a 
feel for the anticipated range of parameters that the program is 


meant +o accept and also handle. This brings in the very 
important concept of defining the BOUNDS within which the vrogram 
must function correctly. Following on from this, is range 


checking af all input parameters so that the program cannot go 
beyond the range that it was designed for and give unexpected 


results. A number of warning messages must be built into the 
program along with error capture and recovery routines. It is 
failure +o define the aperating bounds af a program that causes 
most crashes or rogue behaviour. Even the definition of integer 


variahles at this stage can assist by improving program execution 
time and reducing storage requirements. 
The definition stage should be roughed out on pieces of paper 


kept for later reference. Perhaps better, is to use an old 
exercise boaak. Another benefit of this is that over a period of 
months your progress can be measured and your growth of 
programming ideas’ recorded. Another benefit (although I hardly 


dare mention Gti) 4s. that. it. after the coding stage, a system 
erash accurs and you didn’t SAVE the progran, then all is not 
lost - at least an outline af the program remains. 
4. DESIGN PHASE. Having sorted out I/0 and operating bounds, 
the actual selection of an algorithm to achieve the result is 
commenced. By this time some idea of the number of variables 
required and their type should have begun to gel. This is also 
the stage where your basic honesty in stages 1 and 2 may catch up 
with you! Data structure organisation and algorithm selection are 
really experience-related skills. 


INTRODUCTION TO PROGRAMMING ‘ Se. 


Hence the suggestion to read and/or modify existing programe. 
But do not despair - practice makes perfect. 


a IMPLEMENTATION PHASE. To date very little actual coding 


should have been done; in fact the computer need not even have 
been turned on! Some people may be surprised at how late in the 
task the computer actually enters into the picture. An awful 


lot of planning and organizing can be done off the computer and 
on the "backs of old envelopes". 

It is alsa at this stage that the choice of programming 
language should be made. Is the program time dependant? If it 
is, then it should probably be written is Assembler. If the 
actual timing is not so critical then writing in BASIC with its 
diagnostics and helpful features (so typical of a high level 
language) deem it sensible. Experienced programmers will 
probably use a bit of each in practice. A very sensible 
compromise is to develop the program in interpreted BASIC and 
ance finalized and debugged, compile the BASIC code to speed up 
execution. 

6. EVALUATION PHASE. This is the moment of truth! Does the 
program fulfill all the criteria set out in the definition phase. 

lef |. Gi then you have succesfully achieved your task. Is the 
output as you expected it? Are the results correct? [t is a 
good idea to have a standard set of data to exercise the program 
so that it can be quickly verified after a program alteration. 
Ensure that all logical paths through the program have been 
exercised so that no spurious errors of logic remain undetected. 
Finally, deliberately try values that are out of the intended 
bounds of the program to ensure that you have trapped them and 
that the program recovers from this type of misuse above and 
beyond its’ intended design range. 


As mentioned in part La the affer on programming queries 
still stands. If writing to Bob Kitch please include a SAE. 
BOB KITCH (O7) “37S: S745 
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WRITE PROTECT OVERRIDE SWITCH :- By Joe Leon 


This is to my knowledge the first hardware modification for 
the VZ Disk Drive. As most of you may be awWare it is possible t3 
use the reverse side of your Disks for program storage Simply by 
Cutting a matching notch on the opposite side of the Disk. 
Commercial Notchers are available for that purpose or you can use 
scissors if care is taken. And TioW tO the circuit. 


Only the circuit within the box is needed. The rest iS part 
of the disk drive circuitry and is shown so we can understand 
What is happening. When a notched disk is inserted in the drive 
a smal] light shines through the notch on the disk and 
illuminates the photo transistor (STR1). This has the effect of 
grounding pin to “or; “Ua. When that happens the disk can be 
Written to. If you have a Write Protect Tag covering the notch 
then a ’*DISK WRITE PROTECTED’ message apears if you try to write 
to the disk. 


It follows then that to overcome the write Protect. function 


we must ground pin 13 of U3. The easiest way to ground Din. “LS Oe 
U3 is to connect a wire to the 4K7 resistor and the other end to 
the switch as shown in the diagram. I used a Flashing Red Led as 


a warning for which no resistor is required if used with 5 Volts. 


If you have trouble getting a flashing red led from D. Smiths 
LYry TANDY* Sz This iS a simple project that should’nt present any 
problems. Only the top cover of the disk drive need be removed 
and just follow the diagrams. Once installed the switch wilj 
allow you to write toa the flip side of disks without notching or 
Over a Write protect tag on the front side. Exercise care wher 
using the WRITE PROTECT OVERRIDE SWITCH as your disks are no 
longer WRITE PROTECTED. 


While you have the cover off there are two more modifications 
you can try. When the VZ is accessing the drive you only pet é 
dull red glow from the motor on led. It can be easily replaced 
by a super bright Smm_ LED. The easiest Way to do it without 
removing the circuit board is to cut the Pins of the old led as 


Close to the body of the led as you can. Then place the super 
bright led aver the old pins and push it towards the front tii] 
it nearly touches the rectangular lens and solder in place. Use 
Caution and a heatsink when soldering the led as they are heat 
sensitive. Make sure the led goes in the right way. The 
negative side usually has a flat side on the body. pee circuit 
diagram. 


POWER ON/OFF SWITCH :- 


Again this is a simple project. Just a switch and a led with 
dropping resistor iS required. Or you can dispense with the 
Switch and just use the led with its resistor. Meagan: Bes ae Re 


you where the components are mounted. 


If your drive is still under Warranty then any modifications 
Will void it. Dont forget the responsibility is yours for any 
mishaps. If you doubt your ability to carry ott the 
modifications thendont. 
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WRITE PROTECT OVERRIDE SWITCH :- By Joe Leon 
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YOU PRESSED NEW INSTEAD OF RUN 


DON’T WORKRY :- When you use the NEW command 
the VZ POKES TWO ZERO BYTES 
into the start of the basic program 
to replace these bytes is very easy 
What they tell the computer is 
the address of the next line of 
the basic program. 


ERY -iio: 2= Type in line 10 then return 
Type in line 20 then return 


10--CLS 
20 PRINT 


WITH NO LINE NUMBER TYPE & press return 
FOR I = 321465 to 31476 : PRINT I 3; PEEK( i ): NEXT 
LISTED ON THE VIDEO SHOULD BE 


31465 239 ADDRESS OF THE NEXT LINE (LSB) 
31466 122 ADDRESS OF THE NEXT LINE (MSB) 


we we we ~*~ 


31467 10 LINE NUMBER (LSB) 

31468 0 LINE NUMBER (MSB) 

31469 132 ; TOKEN FOR CLS 

31470 QO ; END OF LINE 

31471 245 ; ADDRESS OF NEXT LINE (LSB) 
31472 122 ; ADDRESS OF NEXT LINE (MSB) 
31473 20 ; LINE NUMBER (LSB) 

31474 0 ; LINE NUMBER (CMSB) 

31475 178 ; TOKEN FOR PRINT 

31476 Oo ; END OF LINE 


31485 & 31466 contains the address of the next line. WITH simple 
maths it is easy to find this address :- 
239 + 256 * 122 = 31471 


CHECK 31471 YOU WILL SEE IT IS THE ADDRESS OF THE NEXT Line. 


List the program you typed. Now press NEW & return. 
List again, WHAT DID YOU GET ? WAS IT NOTHING ? 


res ee PRINT PEEK( 31465 ) ; PEEK( 31466 ) & press return. 
LT SHOULD BE === 20. 6 
TYPE :- POKE 31465,239 : POKE 31466,122 : LIST & press return 


You have just got the program back from the UNKNOWN ! 


Here is an example in basic of what the machine code does. 


10 A = 31467 

ZO B = PEEKC A ) 

30 IF B <> O THEN A=A+1 : GOTO 20 
40 IF B = O THEN A=A+l!l 

50 C=A-(256* INTCA/256) 


BO D=INTCA/256) 
10: POKE. S1465,C 
8O POKE 31466,D 


RESTORE CONT. ~ a - - iat ee Ss = 1 4 


In line 10 'A’ equals the normal start of the basic program plus 
two, 

Line 20 ’B’ looks at what is at location ’A’ 

Line 30 checks if ’B’ is bigger or smaller than zero and adds one 
to ’°’A’ then goes to line 20 

Line 40 checks if °B’ equals zero then °A’ is added with one. (the 
zero inicates the end of the hasic line.) 

Line 50 works out the LEAST SIGNIFICIANT BYTE (LSB). 

Line 60 works out the MOST SIGNIFICIANT BYTE. 

Line 70 POKES 31465 with the LSB. 

Line 80 POKES 31466 with the MSB. 


The above program is only an example to help you understand 
the assembler code later. 


FOR THOSE WITHOUT AN ASSEMBLER PROGRAM. 


10) FOR 1 = =20480 TO) =20391 

20 READ A:POKE I,A: NEXT 

RODATAZ05, 201.1,32,39, 176,205, 167, 40, 17, 236, 122, 19, 26, 254,0, 32 
AODATA250, 19,235, 34, 233, 122, 33.233, 122,34, 164, 120, 205, 248, 26, 35 
SODATAG4. 249. 120. 195~ 25% 26519 4324025,92,.32,52 4.926 S26 82494432402 
SODATA82,69, 83.84, 79, 82.69, 13, 13, 32,32,32,32, 32,66, 89, 32,68, 46 
TODATAT7, 73, 84,67, 72,69, 76. 76, 32,32,86, 75,52, 75,68,65,0,0,0,0 
80 CLS: PRINT"SAVE TO DISK OR TAPE (D7T)* 

90 AIS=INKEYS : AS=INKEYS: IFAS<>"D"ANDAS<> "T" THENSO 

100 SOUNDSO, 1: LFAS="T"THEN180 

110 IF PEEK( 16384 ) = 170,140 

120 PRINT"NO DISK DRIVE YOU NAUGHTY PERSON" 

130 GOTO 180 

140 PRINT"INSERT DISK,CLOSE DOOR & PRESS RETURN" 

150 IFINKEYS< >CHRS(13), 150 

155 SOUNDSO, 1! 

160 BSAVE"RESTORE", BOOO, BOSS 


170 END 

180 FOR I = -24576 TO -24526 

190 READ A: POKE I,A: NEXT 

200 PRINT"INSERT CASSETTE,PRESS PLAY & RECORD THEN RETURN" 


210 IF INKEY$S <> CHRS(13),210 

220 SOUNDSO, 1 

230 POKE 30862,0:POKE 308638, 160: X=USR(0) 

240 END 

250 DATA33,0, 176,34, 164, 120,33,89, 176, 34,249, 120 

260 DATA33..90. 100. 14,241 ,243.2095 2724524:29 15395 293,122 
270 DATAS4, 164, 120,205, 248, 26,35, 34,249, 120 

280 DATA195,25,26,34,82,69, 83,84, 79,.82,.69,34,0,0,0,0 


Lines 10 ta 70 contains the data for restore. 
Lines 80 to 100 checks for saving to disk or tape. 
Line 110 checks for a disk drive. 


Lines 120 to 130 prints an error then goes to tape Save. 

Lines 149 to 170 saves to disk. 

Lines 180 to 190 sets up data for AUTO-RUN tape save. 

Lines 200 to 210 prints message & waits for the return key to he 
pressed. 

Line 230 jumps to the machine code for AUTO-RUN TAPE SAVE. 
Lines 250 to 280 data for auto-run tape save. 


POR MULTIPLE ‘COPIES == DISK TYPE GOTO 1490 
TAPE TYPE GOTO 200. 


RESTORE Corn’ - 
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THE ASSEMBLER CODE. 


CALL O1C9H 


sclear screen. 


Livy Ai. MES ;load HL with the message address. 
CALL 28A7H sprint the message. 
LD DE, 7AECH s;load de with 7VAEC hex. 
SCAN INC DE ,add one to de. 
ED: Ase DES sload ’A’ with what is at the address of DE. 
CP “O0OH stest - is it a zero. 
JR NZ. SCAN ;NO - go back to scan & do it again. 
;YES — continue. 
INC DE ;add one to DE. 
EX DE,HL ;exchange regesters. 
LD (7AESH),HL:load the contents of HL into 7AES HEX. 
LD HL.,7AEQSH ;:load HL with 7AEQS HEX. 
LD (78A44H),HL;load start of program with HL. 
CALL 1AF8H ;sreset program statement table. 
INC HL ;add one to HL. 
LD (78FS9H).HL;load end of program with HL. 
JP 1tA1i9H ;JUMP TO BASIC. 
MES EQU $ ;start of message. 
DEFB ODH ;Carriage return. 
* [C11 spaces] RESTORE* 
DEFB ODH ;carriage return. 
DEFB ODH ;Ccarriage return. 


* €5 spaces] BY D.MITCHELL* 
* (€2 spaces] VK4KDAx 


NOP 


;end of message. 


ORGIN 
START OF PROGRAM BOOO HEX. 
END OF PROGRAM 


NOTE 


:- PROGRAM WILL RUN IN A STANDARD VZ300 OR VZ200 + 


OBOO HEX. 


BOSS HEX. 


16K. 


HGH GAares SsStClore - on - = = os = - 


ASTEROIDS 35020 MATTHEW TAYLOR 
CIRCUS «a & & 1350 GEOFFREY KEEN 
DAWN PATROL 60200 MATTHEW TAYLOR 
DIG OUT 83700 GEOFFREY KEEN 
GALAXON , 29200 MATTHEW TAYLOR 
GHOST HUNTERS 18780 CHRISTIAN WARNER 
HAMBURGER SAM 83600 GEOFFREY KEEN 
HOPPY ae ee 107490 MATTHEW TAYLOR 
LADDER CHALLENGE . . . 25400 MATTHEW TAYLOR 
PANT. .¢: & we & & « « « 26720 BARRY KEEN 
PLANET PATROL 1391 WARREN KEEN 
ROAD WARRIOR . 28370 MATTHEW TAYLOR 
SPACE INVADERS 17290 MATTHEW TAYLOR 
STAR BLASTER Biz ADAM MAGEE 





TECHNICAL REPORT .~ .« =~ «= «=~ =~ = 16 
SHIFT LOCK SWITCHES :- By Joe Leon 
Instead of using a mechanical push on/push off Switch an 


electronic FLIP FLOP can used. Two versions are shown. Leda 
leave it up to you which version you uSe. 


CIRCUIT 1 :- 

This circuit uses one half of a dual flip flop. This is the 
one I used. The P.B. SW. (Push Button Switch) shown can be a 
small momentary switch mounted anywhere convenient. In my case [| 


used the RIGHT SHIFT KEY on the VZ 300 Keyboard. If you decide 
to use this option then the track on either side of the Right 
Shift Key on the Keyboard P.C.B. must be cut. Solder a thin wire 
to each side of the KEYPAD on the track leading to the isolated 
Shift lock switch. The other ends of the two wires go as shown 
On the circuit diagram. While you have the Keyboard apart you 
may decide to mount the 3mm LED as I did. It went in the Right 
Shift Key Cap itself, right above the "I" in the word SHIFT. rt 
looks neat. The choice is yours where it goes. Connecting thes 
Transistor to the keyboard matrix is straightforward. When built 
the LED will let you know when the switch is on. If “the. LED: as 
on, but Shift Lock is not then try reversing the leads from the 
Transistor. 


CIRCUIT 2 :- 


This circuit does the same job as above and is intended for 
Persons who built the softstart switch as shown in the November 


issue, page 8. It uses the left over gates from that circuit. 
CAUTION :- 

Both IC’S are CMOS type and special handling precautions mus: 
be observed. Do not touch the pins on the IC’S as static can 
destroy them. Use a socket for the IC just to be safe. Also all 
unused INPUTS must be grounded or taken to +5V. Pinouts for both 


IC*’S are shown to help intending constructors. 





And | bought this one to explain 
the manual of the first one’ 
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SHIFT LOCK SWITCHES :- By Joe LEon 
CIRCUIT 1 
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IIMDERSTANDING WYOoOoOUR We i ¢€C} os 1 
NOTE :- Gee insue &, pagze 19 for LLISTing of DLINE. 


DLINE is the deluxe version of LNs When you have entered 
Pile 1 Ne check the accuracy af the DATA statements with this 
direct command: 


FORR=29184 TO 29760: READA:Z=Z+A: NEXT: PRINTS 


If vour answer is not 6319, then recheck all the numbers in 
the DATA statements at the end of DLINE. When RUNSOOO, DLINE 
will ask for a line number. Enter the number of the program line 
you Want analysed, oar enter 4 basic word. If you enter a word, 
DLINE will search through the word table (token list tatle) for 
the word and print the token code for that word, then ask for a 
line number again. 


When a line number has been entered, DLINE will ask for a 


token. If you want DLINE to seek out a particular token code in 
the line. then enter that token and DLINE will display each hyte 
in the line in continuous sequence, pausing only when it 


encounters an instance af the token. If you do not want PLINE t9 
search for a particular token, then simply press <RETURN> and 
DLINE will display the first five bytes of the line and pause. 
Press <SPACE> ta single-step through the remainder of the line. 
DLINE will display the address of the memory cell for each byte 
hyte in the line (first. .second,third,etc.), the byte itself, 
then the character oar hasic word designated by the byte (under 
the ? heading) and, finally, the negative PEEK/POKE address af 
the byte if the address is greater than: S276. Whenever DLINE 
pauses, you can press ¢9> or <L> or <X> key to activate a 
particular POKE facility. 


CAV PLINE will ask for a POKE address and then POKE the number 
149 (token cade for LET) to that address. 


Le DLINE will ask for a POKE address, then for a TOKEN, and 
POKE the token number to the address. 


ies DLINE will ask for a TOKEN and then POKE the token number 
to the last address displayed on the screen. 


rA>: Pressing this key will reRUN DLINE. 
BOR00 IT FZ-192THEN PRINT"VARPTR";: RETURN 


This line in DLINE recognises the token for VARPTR and lists 


this word when it encounters the token. Other similar lines can 
he inserted inta DLINE for ather words that are not functional in 
the ward table. They should have line numbers greater than SORBOO0 


and less than SO0320. 
FG. S5O3021FZ=19RTHEN PRINT"STRINGS"; >: RETURN 


Such lines should tbe inserted after DLINE has heen merged 
with another program, hecause DLINE is already close to the 
maximum length of a prorram that can be merged using the MERGE 
routine aceanmpanying this article. Any further lines will take 
it aver the Limo ts Thase of you who have a disk drive can run 
DLINE and then BSAVE a bhinary program of the machine code 
rantines used hy DLINE:- 


LIN DERSTANDING woIrR Vaz CONT - - it? 


BSAVE-LEODE” . (2004 724C and then delete all the DATA statements 
and the READ/POKE routine from DLINE. The memory gained can then 
be used to install a number of statements for recognising and 
listing various nonfunctional words as indicated above. 


Line SO9190 should now read: 


S00190 ITFPEEK (29223) =33ANDPEEK(29224)= 233THENSOO3O and a line 
SOO?O entered thus: 


S00Z0O INPUTB: BLOAD"LCODE" 


The INPUT statement is simply a precaution to prevent you 
from initiating BLOADing af LCODE without a disk in the drive or 
the door closed (you’ve had that experience too have you?). 


Incidentally. if you want to use VZ disk commands in 
canditional statements, the trick is to insert a colon between 
THEN and the disk command, like thisi:- 


RO TFK=SOTHEN: BLOAD"PROGRAN" 


The deluxe version of line is obviously too long to type in 
every time you want to append it to a program. Salvation is at 
hand in the form of a merge routine. You need only type DLINE in 
once, save it on tape or disk, and thenceforth use the MER 
program ta join DLINE to other programs. 


MER allows you to join ane program onto the end af another so 
that thev become a single program. Type in MER and save. Check 
the length af MER with this length command:- 


PRINTPEEK (30969)+PEEK (30970)*25 6-31465 


The answer should be 2370. Then check the machine code af the 
MERGE routine with this command sequence: 


FORR=21273T031254:READA: B=B+A:N EXT: PRINTB 


The answer shauld he 9118. It not, check aut all the 
mimhers in the DATA statements. When RUN, MER sets up a machine 
code MERGE routine in the communications region. MERGE is the 
program which does the adding on. 


PROG 1 is the program you wish to add on. 
PROG 2 is the program to which you want to add PROG 1. 


The maximum leneth for PROG 1 is 1534 bytes. Tf you have any 
doubts as toa whether PROG 1 exceeds the maximum length, then 
check the Jleneth with the ahove command. For trouble-free 
merging, ensure that the line numbers for al) the lines in PROG 1 
are greater than all the line numbers in PROG 2. 


Enter the following sequence of commands to carry out a merger 
(CRUN and CLOAD if you are using a cassette recorder): 


RUN "MER" "Transfers M. Code MERGE to communications region 
LOAD"PROG 1" ?Use your name for PROG I 
PRINTUSE(S) "MERGE cornies PROG 1 to video memory 


LOAD"PROG 2" *Use your name for PROG 2 
PRINTUSR(&) "MERGE adds PROG 1 anta end af PROG 2 


UINIDERSTALIDING YouR V2 COMT - - a ©) 


Most routines you would want to merge With another program 
would be less than the maximum length permitted (1534). 


However, should you want to add on a longer routine, you 
can do it in stages. When you load PROG 1, chop PROG 1 in half 
by using the DELETE command (see Table X) to remove the top end 
@i- FROG. ds and complete the merge. Save the result; this will 
be your new PROG 2. Now repeat the merge sequence of commands 
from LOAD"PROG 1" onwards. 


This time DELETE the bottom part of PROG 1 and merge the 
remainder with the new PROG 2. 


Once MER has been run the MERGE routine can be used to merge 
any number of pairs of programs without having to reRUN the MER 
program each time. 


Merge will add on PROG 1 to PROG 2 regardless of the line 
numbers of the two programs. The result could be that a routine 
is joined to the end of PROG 2 that has the same line numbers as 
PROG 2 or some part of PROG 2. This is an opportunity to get two 
or more programs to reside in program memory simultaneously. 
With the proper POKEs to start of program pointer you cen then 
RUN the program of your choice. 


LLiStine for: MERee: 


10 FORR=31273T031354: READA: POKER, A: NEXT 

20 POKE30862, 41: POKE30863, 122 

390 DATAI7S, 42, 249, 120.17, 233, 122,237,82,68,77,237,67,0, 114,33 

AO DATA233, 122, 17,2, 114,237, 176,33,71, 122,34, 142, 120,201, 237 

50 DATAS1. 249, 120, 27,27, 107, 98. 237, 75,0, 114,9, 34, 249, 120 

GO DATA33,2, 114, 237, 176, 33,41, 122, 34, 142, 120,175, 17, 233, 122,98 
70 DATAIOT7, 190, 35, 32,2, 190, 200, 35, 35, 35, 190,32, 252, 35, 235, 115,95 
80 DATA114,24,235 


CGed COPYRIGHT is retained by ROBERT QUINN on the series 
UNDERSTANDING YOUR VZ. 





